<!DOCTYPE html><html lang="zh-CN" data-theme="light"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width,initial-scale=1"><title>Tommy Emmanuel | 小李博客</title><meta name="author" content="小李博客"><meta name="copyright" content="小李博客"><meta name="format-detection" content="telephone=no"><meta name="theme-color" content="#ffffff"><meta name="description" content="Stay Close To Me             Since we met             Mombasa             Angelina             These who wait             Over the rainbow             Windy and warm              Strutting It">
<meta property="og:type" content="website">
<meta property="og:title" content="Tommy Emmanuel">
<meta property="og:url" content="http://xiaoliblog.cn/photograph/fingerstyle.html">
<meta property="og:site_name" content="小李博客">
<meta property="og:description" content="Stay Close To Me             Since we met             Mombasa             Angelina             These who wait             Over the rainbow             Windy and warm              Strutting It">
<meta property="og:locale" content="zh_CN">
<meta property="og:image" content="https://cdn.jsdelivr.net/npm/butterfly-extsrc@1/img/default.jpg">
<meta property="article:published_time" content="2021-01-25T04:44:17.000Z">
<meta property="article:modified_time" content="2021-02-16T06:36:31.984Z">
<meta property="article:author" content="小李博客">
<meta name="twitter:card" content="summary">
<meta name="twitter:image" content="https://cdn.jsdelivr.net/npm/butterfly-extsrc@1/img/default.jpg"><link rel="shortcut icon" href="https://cdn.jsdelivr.net/gh/xiaoliblog/image@6b5e7ef72be1c8973d94e5a9c49accbf775ad820/2021/02/01/c485da031fe0e464d04eaba8a66c4a8f.png"><link rel="canonical" href="http://xiaoliblog.cn/photograph/fingerstyle"><link rel="preconnect" href="//cdn.jsdelivr.net"/><link rel="preconnect" href="//busuanzi.ibruce.info"/><link rel="stylesheet" href="/css/index.css"><link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@fortawesome/fontawesome-free/css/all.min.css" media="print" onload="this.media='all'"><link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/node-snackbar/dist/snackbar.min.css" media="print" onload="this.media='all'"><link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/instantsearch.js@2.10.5/dist/instantsearch.min.css" media="print" onload="this.media='all'"><script src="https://cdn.jsdelivr.net/npm/instantsearch.js@2.10.5/dist/instantsearch.min.js" defer></script><script>const GLOBAL_CONFIG = { 
  root: '/',
  algolia: {"appId":"RTG4CPNBLJ","apiKey":"f1745bdad68ceec57653b78244fe332c","indexName":"MyBlogIndex","hits":{"per_page":6},"languages":{"input_placeholder":"搜索文章","hits_empty":"找不到您查询的内容：${query}","hits_stats":"找到 ${hits} 条结果，用时 ${time} 毫秒"}},
  localSearch: undefined,
  translate: {"defaultEncoding":2,"translateDelay":0,"msgToTraditionalChinese":"繁","msgToSimplifiedChinese":"簡"},
  noticeOutdate: undefined,
  highlight: {"plugin":"highlighjs","highlightCopy":true,"highlightLang":true,"highlightHeightLimit":200},
  copy: {
    success: '复制成功',
    error: '复制错误',
    noSupport: '浏览器不支持'
  },
  relativeDate: {
    homepage: false,
    post: false
  },
  runtime: '天',
  date_suffix: {
    just: '刚刚',
    min: '分钟前',
    hour: '小时前',
    day: '天前',
    month: '个月前'
  },
  copyright: {"limitCount":100,"languages":{"author":"作者: 小李博客","link":"链接: ","source":"来源: 小李博客","info":"著作权归作者所有。商业转载请联系作者获得授权，非商业转载请注明出处。"}},
  lightbox: 'mediumZoom',
  Snackbar: {"chs_to_cht":"你已切换为繁体","cht_to_chs":"你已切换为简体","day_to_night":"你已切换为深色模式","night_to_day":"你已切换为浅色模式","bgLight":"#49b1f5","bgDark":"#121212","position":"top-center"},
  source: {
    jQuery: 'https://cdn.jsdelivr.net/npm/jquery@latest/dist/jquery.min.js',
    justifiedGallery: {
      js: 'https://cdn.jsdelivr.net/npm/justifiedGallery/dist/js/jquery.justifiedGallery.min.js',
      css: 'https://cdn.jsdelivr.net/npm/justifiedGallery/dist/css/justifiedGallery.min.css'
    },
    fancybox: {
      js: 'https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@latest/dist/jquery.fancybox.min.js',
      css: 'https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@latest/dist/jquery.fancybox.min.css'
    }
  },
  isPhotoFigcaption: false,
  islazyload: false,
  isanchor: true
}</script><script id="config-diff">var GLOBAL_CONFIG_SITE = { 
  isPost: false,
  isHome: false,
  isHighlightShrink: false,
  isToc: false,
  postUpdate: '2021-02-16 14:36:31'
}</script><noscript><style type="text/css">
  #nav {
    opacity: 1
  }
  .justified-gallery img {
    opacity: 1
  }

  #recent-posts time,
  #post-meta time {
    display: inline !important
  }
</style></noscript><script>(win=>{
    win.saveToLocal = {
      set: function setWithExpiry(key, value, ttl) {
        if (ttl === 0) return
        const now = new Date()
        const expiryDay = ttl * 86400000
        const item = {
          value: value,
          expiry: now.getTime() + expiryDay,
        }
        localStorage.setItem(key, JSON.stringify(item))
      },

      get: function getWithExpiry(key) {
        const itemStr = localStorage.getItem(key)

        if (!itemStr) {
          return undefined
        }
        const item = JSON.parse(itemStr)
        const now = new Date()

        if (now.getTime() > item.expiry) {
          localStorage.removeItem(key)
          return undefined
        }
        return item.value
      }
    }
  
    win.getScript = url => new Promise((resolve, reject) => {
      const script = document.createElement('script')
      script.src = url
      script.async = true
      script.onerror = reject
      script.onload = script.onreadystatechange = function() {
        const loadState = this.readyState
        if (loadState && loadState !== 'loaded' && loadState !== 'complete') return
        script.onload = script.onreadystatechange = null
        resolve()
      }
      document.head.appendChild(script)
    })
  
      win.activateDarkMode = function () {
        document.documentElement.setAttribute('data-theme', 'dark')
        if (document.querySelector('meta[name="theme-color"]') !== null) {
          document.querySelector('meta[name="theme-color"]').setAttribute('content', '#0d0d0d')
        }
      }
      win.activateLightMode = function () {
        document.documentElement.setAttribute('data-theme', 'light')
        if (document.querySelector('meta[name="theme-color"]') !== null) {
          document.querySelector('meta[name="theme-color"]').setAttribute('content', '#ffffff')
        }
      }
      const t = saveToLocal.get('theme')
    
          if (t === 'dark') activateDarkMode()
          else if (t === 'light') activateLightMode()
        
      const asideStatus = saveToLocal.get('aside-status')
      if (asideStatus !== undefined) {
        if (asideStatus === 'hide') {
          document.documentElement.classList.add('hide-aside')
        } else {
          document.documentElement.classList.remove('hide-aside')
        }
      }
    
    const fontSizeVal = saveToLocal.get('global-font-size')
    if (fontSizeVal !== undefined) {
      document.documentElement.style.setProperty('--global-font-size', fontSizeVal + 'px')
    }
    })(window)</script><link rel="stylesheet" href="/css/MyStyle/MyStyle.css" media="defer" onload="this.media='all'"/><link rel="stylesheet" href="/css/MyStyle/tagStyle.css" media="defer" onload="this.media='all'"/><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/zykjofficial/zykjresource@master/css/font-awesome-animation.min.css" media="defer" onload="this.media='all'"/><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/sviptzk/StaticFile_HEXO@latest/butterfly/css/font-awesome-animation.min.css" media="defer" onload="this.media='all'"><link rel="stylesheet" href="https://cdn.jsdelivr.net/gh/sviptzk/StaticFile_HEXO@latest/butterfly/css/plugins.min.css" media="defer" onload="this.media='all'"><meta name="generator" content="Hexo 5.2.0"><link rel="alternate" href="/atom.xml" title="小李博客" type="application/atom+xml">
</head><body><div id="web_bg"></div><div id="sidebar"><div id="menu-mask"></div><div id="sidebar-menus"><div class="author-avatar"><img class="avatar-img" src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@6b5e7ef72be1c8973d94e5a9c49accbf775ad820/2021/02/01/c485da031fe0e464d04eaba8a66c4a8f.png" onerror="onerror=null;src='/img/friend_404.gif'" alt="avatar"/></div><div class="site-data"><div class="data-item is-center"><div class="data-item-link"><a href="/archives/"><div class="headline">文章</div><div class="length-num">210</div></a></div></div><div class="data-item is-center"><div class="data-item-link"><a href="/tags/"><div class="headline">标签</div><div class="length-num">38</div></a></div></div><div class="data-item is-center"><div class="data-item-link"><a href="/categories/"><div class="headline">分类</div><div class="length-num">56</div></a></div></div></div><hr/><div class="menus_items"><div class="menus_item"><a class="site-page" href="/"><i class="fa-fw fas fa-home"></i><span> 主页</span></a></div><div class="menus_item"><a class="site-page" href="/link/"><i class="fa-fw fas fa-link"></i><span> 友链</span></a></div><div class="menus_item"><a class="site-page" href="/box/"><i class="fa-fw fa fa-briefcase"></i><span> 工具箱</span></a></div><div class="menus_item"><a class="site-page" href="javascript:void(0);"><i class="fa-fw fas fa-book"></i><span> 找文章</span><i class="fas fa-chevron-down expand"></i></a><ul class="menus_item_child"><li><a class="site-page child" href="/archives/"><i class="fa-fw fas fa-archive"></i><span> 归档</span></a></li><li><a class="site-page child" href="/tags/"><i class="fa-fw fas fa-tags"></i><span> 标签</span></a></li><li><a class="site-page child" href="/categories/"><i class="fa-fw fa fa-folder-open"></i><span> 分类</span></a></li></ul></div><div class="menus_item"><a class="site-page" href="/about/"><i class="fa-fw fa fa-address-card"></i><span> 关于</span></a></div><div class="menus_item"><a class="site-page" href="/messageboard/"><i class="fa-fw fa fa-paper-plane"></i><span> 留言</span></a></div></div></div></div><div class="page" id="body-wrap"><header class="not-top-img" id="page-header"><nav id="nav"><span id="blog_name"><a id="site-name" href="/">小李博客</a></span><div id="menus"><div id="search-button"><a class="site-page social-icon search"><i class="fas fa-search fa-fw"></i><span> 搜索</span></a></div><div class="menus_items"><div class="menus_item"><a class="site-page" href="/"><i class="fa-fw fas fa-home"></i><span> 主页</span></a></div><div class="menus_item"><a class="site-page" href="/link/"><i class="fa-fw fas fa-link"></i><span> 友链</span></a></div><div class="menus_item"><a class="site-page" href="/box/"><i class="fa-fw fa fa-briefcase"></i><span> 工具箱</span></a></div><div class="menus_item"><a class="site-page" href="javascript:void(0);"><i class="fa-fw fas fa-book"></i><span> 找文章</span><i class="fas fa-chevron-down expand"></i></a><ul class="menus_item_child"><li><a class="site-page child" href="/archives/"><i class="fa-fw fas fa-archive"></i><span> 归档</span></a></li><li><a class="site-page child" href="/tags/"><i class="fa-fw fas fa-tags"></i><span> 标签</span></a></li><li><a class="site-page child" href="/categories/"><i class="fa-fw fa fa-folder-open"></i><span> 分类</span></a></li></ul></div><div class="menus_item"><a class="site-page" href="/about/"><i class="fa-fw fa fa-address-card"></i><span> 关于</span></a></div><div class="menus_item"><a class="site-page" href="/messageboard/"><i class="fa-fw fa fa-paper-plane"></i><span> 留言</span></a></div></div><div id="toggle-menu"><a class="site-page"><i class="fas fa-bars fa-fw"></i></a></div></div></nav></header><main class="layout hide-aside" id="content-inner"><div id="page"><div id="article-container"><h1 class="page-title">Tommy Emmanuel</h1><h1 id="Stay-Close-To-Me"><a href="#Stay-Close-To-Me" class="headerlink" title="Stay Close To Me"></a>Stay Close To Me</h1><div class="justified-gallery"><p><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@30f8a45b78f1624581e66792bee2dbc9f9f62331/2021/01/25/abdf3cd4009feb31eddc09562605ffb5.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@2ce8aa62aac394a93e7ddda222af1d84c8a218be/2021/01/25/31d365e528c647a1f0f901a1e7a59608.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@0dab7b8c0009fec0a160c6912620624b0270de6d/2021/01/25/ba6256bf0ceaa511079fdb7ac30d53cc.png"></p>
          </div>

<h1 id="Since-we-met"><a href="#Since-we-met" class="headerlink" title="Since we met"></a>Since we met</h1><div class="justified-gallery"><p><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@8d6f1b75dd0ffc4f43ff1a6cfa3a8537e18fc373/2021/01/25/a1c2bd967acc199c4cc4dd1d0ac0d2fb.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@52e2301e5f4720575eee2c8964129bd50bc92124/2021/01/25/b2d7a46f38a1c54568b03e1ce463f219.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@365d360ba362057a0f7d22e0eec03491abb2e7f7/2021/01/25/ad4d21cb5b171397a8fe42a9f8ca76b0.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@88cd7123a47a5e5f2ade23883205334737e41272/2021/01/25/c50db79f96708b2dcbca12f0f54edd7e.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@4efb0ba854d41474b509892d8a524e39ad84c940/2021/01/25/2019aa5f1eb0f86876d4a4abd2acf9b5.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@432be895d8906d9ad32160905ea0f18f0a5462a9/2021/01/25/d487fe8e89cd3b83148d2839e1200942.png"></p>
          </div>

<h1 id="Mombasa"><a href="#Mombasa" class="headerlink" title="Mombasa"></a>Mombasa</h1><div class="justified-gallery"><p><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@ec8bf6d8fed0c20b9200745990e0671311a1971a/2021/01/25/512b37be25260973bc6fff3895692ce1.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@133679994c0c44364c119d2e5d558e62596f494c/2021/01/25/78efa72e1f64ff92ecf31f5c59357136.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@82cfe8446fafdf4d9d1d9e7c27c5b5caf721c112/2021/01/25/b1c6ed39192925ab883dd6dcb739ed58.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@ae941fc8a5c4e19c25766ff0e4b57b7d77d700c1/2021/01/25/64f5d59cc142bbbde9c178f3148d8d47.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@a12bdff36b7d737cf856002e2d4d449385d2df23/2021/01/25/dfdc20ffe5a5dbe4f80c8dbdbc9dd357.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@b8b953bd3c9568892ef6e7160a06e25d28ad544d/2021/01/25/031dbffb01ac1cfa0c6f8f504cd9858f.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@118325e9f9e91a254e2a1dd8f95e4141ffd80195/2021/01/25/f1dcda28a90fe4213bdab98aba1549f3.png"></p>
          </div>

<h1 id="Angelina"><a href="#Angelina" class="headerlink" title="Angelina"></a>Angelina</h1><div class="justified-gallery"><p><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@7c62f05a684125c0ebcd4eb89a126956892ccdf6/2021/01/25/4f1a08e9cc0f4dbe0ffa2cd1374c8771.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@124973bc555437f5cd2de2bf008609c50ba78d05/2021/01/25/f0f7cade0aa1acb4e62f8ec383198332.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@609d8738408f163b6f6a488d428016777f4f127b/2021/01/25/d0775a4ff8bb730986db18af45c1be42.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@899dd6de80a3473a4b2961c3bd87d632b411817b/2021/01/25/5e7a36efe5dae872d0d5dbb2d499a324.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@5677af11df6b4104ba0f5c9cd490644f4a9cbbb4/2021/01/25/bf98223bf0f1b27fa63432be96c80002.png"><br><a target="_blank" rel="noopener" href="https://cdn.jsdelivr.net/gh/xiaoliblog/image@5677af11df6b4104ba0f5c9cd490644f4a9cbbb4/2021/01/25/bf98223bf0f1b27fa63432be96c80002.png"></a><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@0044bc009734442d29a7f1b477820f4af45fa572/2021/01/25/3d6b7273bcb5dc443b5b646357fd13ed.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@17d1ded87c69671db02750968dcec4efb7e296d3/2021/01/25/02c84f2a799e21163ef0afdc10c5e2aa.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@f7631cd7b28533b68b75069bf43de00ebf0e2b60/2021/01/25/a3bbe89175b95abb1350ccd812d8970d.png"></p>
          </div>

<h1 id="These-who-wait"><a href="#These-who-wait" class="headerlink" title="These who wait"></a>These who wait</h1><div class="justified-gallery"><p><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@cf67cf9d9e720e41daa7300c38a91d7a1c6d879d/2021/01/25/be6962ad8a5f918e7621342a0fd02b1a.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@dcc5e500b7694aeb704b4358023075352d641dd4/2021/01/25/0ae8c778ba4cb518ec6b90a710586c72.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@f3117f18cc98eb391bf9ad5b9ffbb0fb1685739b/2021/01/25/5974e3c436bd2b6caf157401722f0942.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@b0578986f4a03b1258893acdb360db5feb86c3fa/2021/01/25/2cbd8fc3f13fe285f70d53637d914db8.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@79f4374eb6e5ea063081d8734ec40b2ef856796b/2021/01/25/412c830c9328b8d67851bd05e95425e1.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@7008ca86473439a76cfe70453acdd280800895d1/2021/01/25/a4cd97bf4e5e3f02e1bca043b1d309a4.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@b2b9217f5fb7dddc357d4a8233d626bf3d9f8445/2021/01/25/cfa55128111cf4bb2c888f196e24c1fd.png"></p>
          </div>

<h1 id="Over-the-rainbow"><a href="#Over-the-rainbow" class="headerlink" title="Over the rainbow"></a>Over the rainbow</h1><div class="justified-gallery"><p><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@e85489e79bf269c3f18430b2eb8849843eb6c6e3/2021/01/25/83d9382a0b6c25fe7cc65c7b26fac89a.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@2854e2b3bda18694cb4c4096ed05bcc8b2bb8a88/2021/01/25/bd16ea352664aa511b59f84872d3d11b.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@f2bde3950f439dec274dfa891cfc28bcfefffed9/2021/01/25/0bfd33d1d29cf7cee89e91fcef3286f4.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@226ab1a02d46be8d2d480bc5614f860814cba5d8/2021/01/25/f68434075e06f2bf505ddc99890b4494.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@1b56a5594106125ed7e860474444353dde3d4277/2021/01/25/c6aea708b31fe9883bc0988a6f5b79d3.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@8be59395f63b0f60749702ad629b0eb7e8e00149/2021/01/25/966e46054bd5e71951a517ef33549f51.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@f9ca088f61b782c2762a7121884b25cfc15116b8/2021/01/25/ac8ad179810b6dc68a777a5aa659f128.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@fab9ae8c754b596506318513ebd3f5672aa1a094/2021/01/25/3a183a067122d134314832ea79db146b.png"></p>
          </div>

<h1 id="Windy-and-warm"><a href="#Windy-and-warm" class="headerlink" title="Windy and warm"></a>Windy and warm</h1><div class="justified-gallery"><p><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@9bf7fd7aba4c1b7677c849e16097b983fc8c7909/2021/01/25/d1ddfb9c5b0b3ddc344aa60a63cbadc6.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@69b3f9739c37337b98f2fdbcfb969eece3c160ed/2021/01/25/b0bca812bd8acf7faeef6c5a5a197d42.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@f62c4b57b7ac25a03c84ac71ec8e16d8ac008d38/2021/01/25/831e331b5a716c8303b3ff3696776a3d.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@9adddb08ee0cf32a26619d8f3afc049aa1d5cea9/2021/01/25/fd80ccc3f83fa7ca995eba49ce686ecd.png"></p>
          </div>


<h1 id="Strutting-It"><a href="#Strutting-It" class="headerlink" title="Strutting It"></a>Strutting It</h1><div class="justified-gallery"><p><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@eff8154e805993f1b5f5b7917314c12d14af681e/2021/01/26/ca0cbdef3b091c644ca84ffb3b14f6a7.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@9eb82d2f3239c7cb114bb2081ebc47e248ca0686/2021/01/26/d5e50de273009c7eb370bfe80512e302.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@8918fe72e8b4a10da2cf809d00d3d4aea3e0ed26/2021/01/26/a28d62c0f94fe7c67d500d26314f1ead.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@2360ed6b0d69f171f8d1b4b314f64418cc40a05e/2021/01/26/10407ff05aaa6996d1a64d5c615270cd.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@4a31dfa4f470f96455138b9a0dd8464fd2bd2aa5/2021/01/26/563f1f7a20f54fd60c68d538d05281af.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@bdbc861139092f15e171cf555281f8b5cdf6a019/2021/01/26/14f246118694d65c51e41387654e167b.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@6345f9dde6aed13c095038d049ed7d107ef1d057/2021/01/26/43297a6ad6787a2df3a2d47f37149e79.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@27aee505c2c878133420a2bffa1130da8f062c2f/2021/01/26/e46301fe276dd96982ea87a9851916d3.png"></p>
          </div>

<h1 id="Drive-time"><a href="#Drive-time" class="headerlink" title="Drive time"></a>Drive time</h1><div class="justified-gallery"><p><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@1f5d51064677d4c8bc76e1c321631eb5cf17737b/2021/01/25/8aa1a53a43b32e392483f0a5bd4f96ed.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@0b7a6748e86d43f5a996da9478161916739628f9/2021/01/25/0500c81e90ccd0e7e109e8219216b30b.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@61c0b95bafae180061f965fa139ece243144cc29/2021/01/25/033de6f70d793c9cd6dd2b4cea93502e.png"><br><img src="https://cdn.jsdelivr.net/gh/xiaoliblog/image@edb7473245baf5c7b66dabf32b1d395e14e6b425/2021/01/25/f6a82fa734b7ba9ce6d9207ee7ff8dec.png"></p>
          </div></div></div></main><footer id="footer"><div id="footer-wrap"><div class="copyright">&copy;2020 - 2021 By 小李博客</div><div class="framework-info"><span>框架 </span><a target="_blank" rel="noopener" href="https://hexo.io">🎯Hexo</a><span class="footer-separator">|</span><span>主题 </span><a target="_blank" rel="noopener" href="https://github.com/jerryc127/hexo-theme-butterfly">🎉Butterfly</a></div><div class="footer_custom_text"><span><a style="margin-inline:5px" target="_blank" href="https://hexo.io/"><img src="https://img.shields.io/badge/Frame-Hexo-blue?style=flat&logo=hexo" title="博客框架为Hexo"></a><a style="margin-inline:5px" target="_blank" href="https://butterfly.js.org/"><img src="https://img.shields.io/badge/Theme-Butterfly-6513df?style=flat&logo=bitdefender" title="主题采用butterfly"></a><a style="margin-inline:5px" target="_blank" href="https://www.jsdelivr.com/"><img src="https://img.shields.io/badge/CDN-jsDelivr-orange?style=flat&logo=jsDelivr" title="本站使用JsDelivr为静态资源提供CDN加速"></a><a style="margin-inline:5px" target="_blank" href="https://vercel.com/ "><img src="https://img.shields.io/badge/Hosted-Vercel-brightgreen?style=flat&logo=Vercel" title="本站采用双线部署，默认线路托管于Vercel"></a><a style="margin-inline:5px" target="_blank" href="https://coding.net/ "><img src="https://img.shields.io/badge/Hosted-Coding-0cedbe?style=flat&logo=Codio" title="本站采用双线部署，联通线路托管于Coding"></a><a style="margin-inline:5px" target="_blank" href="https://github.com/"><img src="https://img.shields.io/badge/Source-Github-d021d6?style=flat&logo=GitHub" title="本站项目由Gtihub托管"></a><a style="margin-inline:5px" target="_blank" href="http://creativecommons.org/licenses/by-nc-sa/4.0/"><img src="https://img.shields.io/badge/Copyright-BY--NC--SA%204.0-d42328?style=flat&logo=Claris" title="本站采用知识共享署名-非商业性使用-相同方式共享4.0国际许可协议进行许可"></a></span></div><div class="icp"><a target="_blank" rel="noopener" href="https://beian.miit.gov.cn/"><img class="icp-icon" src="/img/icp.png" alt="ICP"/><span>湘ICP备2021002541号</span></a></div></div></footer></div><div id="rightside"><div id="rightside-config-hide"><button id="font-plus" type="button" title="放大字体"><i class="fas fa-plus"></i></button><button id="font-minus" type="button" title="缩小字体"><i class="fas fa-minus"></i></button><button id="translateLink" type="button" title="简繁转换">繁</button><button id="darkmode" type="button" title="浅色和深色模式转换"><i class="fas fa-adjust"></i></button></div><div id="rightside-config-show"><button id="rightside_config" type="button" title="设置"><i class="fas fa-cog fa-spin"></i></button><button id="chat_btn" type="button" title="rightside.chat_btn"><i class="fas fa-sms"></i></button><button id="go-up" type="button" title="回到顶部"><i class="fas fa-arrow-up"></i></button></div></div><div id="algolia-search"><div class="search-dialog"><div class="search-dialog__title" id="algolia-search-title">Algolia</div><div id="algolia-input-panel"><div id="algolia-search-input"></div></div><hr/><div id="algolia-search-results"><div id="algolia-hits"></div><div id="algolia-pagination"></div><div id="algolia-stats"></div></div><span class="search-close-button"><i class="fas fa-times"></i></span></div><div id="search-mask"></div></div><div><script src="/js/utils.js"></script><script src="https://cdn.jsdelivr.net/npm/vue@2.6.11"></script><script src="/js/main.js"></script><script defer src="/js/tw_cn.js"></script><script defer src="https://cdn.jsdelivr.net/npm/medium-zoom/dist/medium-zoom.min.js"></script><script src="https://cdn.jsdelivr.net/npm/instant.page/instantpage.min.js" type="module" defer></script><script defer src="https://cdn.jsdelivr.net/npm/node-snackbar/dist/snackbar.min.js"></script><script defer src="/js/search/algolia.js"></script><div class="js-pjax"><script>if (!window.MathJax) {
  window.MathJax = {
    loader: {
      source: {
        '[tex]/amsCd': '[tex]/amscd'
      }
    },
    tex: {
      inlineMath: [ ['$','$'], ["\\(","\\)"]],
      tags: 'ams'
    },
    options: {
      renderActions: {
        findScript: [10, doc => {
          for (const node of document.querySelectorAll('script[type^="math/tex"]')) {
            const display = !!node.type.match(/; *mode=display/)
            const math = new doc.options.MathItem(node.textContent, doc.inputJax[0], display)
            const text = document.createTextNode('')
            node.parentNode.replaceChild(text, node)
            math.start = {node: text, delim: '', n: 0}
            math.end = {node: text, delim: '', n: 0}
            doc.math.push(math)
          }
        }, ''],
        addClass: [200,() => {
          document.querySelectorAll('mjx-container:not([display=\'true\']').forEach( node => {
            const target = node.parentNode
            if (!target.classList.contains('has-jax')) {
              target.classList.add('mathjax-overflow')
            }
          })
        }, '', false]
      }
    }
  }
  
  const script = document.createElement('script')
  script.src = 'https://cdn.jsdelivr.net/npm/mathjax@3/es5/tex-mml-chtml.js'
  script.id = 'MathJax-script'
  script.async = true
  document.head.appendChild(script)
} else {
  MathJax.startup.document.state(0)
  MathJax.texReset()
  MathJax.typeset()
}</script><script>if (document.getElementsByClassName('mermaid').length) {
  if (window.mermaidJsLoad) mermaid.init()
  else {
    getScript('https://cdn.jsdelivr.net/npm/mermaid/dist/mermaid.min.js').then(() => {
      window.mermaidJsLoad = true
      mermaid.initialize({
        theme: 'default',
      })
      false && mermaid.init()
    })
  }
}</script></div><script defer src="//lib.baomitu.com/jquery/3.5.1/jquery.min.js"></script><script defer src="https://myhkw.cn/api/player/160561664166" id="myhk" key="160561664166" m="1"></script><div><canvas id="snow" style="position:fixed;top:0;left:0;width:100%;height:100%;z-index:99999;pointer-events:none"></canvas></div><script>const notMobile = (!(navigator.userAgent.match(/(phone|pad|pod|iPhone|iPod|ios|iPad|Android|Mobile|BlackBerry|IEMobile|MQQBrowser|JUC|Fennec|wOSBrowser|BrowserNG|WebOS|Symbian|Windows Phone)/i)));</script><scrip async type="text/javascript" src="https://cdn.jsdelivr.net/gh/Candinya/Kratos-Rebirth@latest/source/js/snow.min.js"></scrip><scrip defer src="https://cdn.jsdelivr.net/npm/hexo-theme-volantis@latest/source/js/issues.min.js"></scrip><script async data-pjax src="//busuanzi.ibruce.info/busuanzi/2.3/busuanzi.pure.mini.js"></script><script>var gitcalendar = new Vue({
  el: '#gitcalendar',
  data: {
    simplemode: true, 
    user: 'xiaoliblog',
    fixed: 'fixed',
    px: 'px',
    x: '',
    y: '',
    span1: '',
    span2: '',
    month: ['一月', '二月', '三月', '四月', '五月', '六月', '七月', '八月', '九月', '十月', '十一月', '十二月'],
    monthchange: [],
    oneyearbeforeday: '',
    thisday: '',
    amonthago: '',
    aweekago: '',
    weekdatacore: 0,
    datacore: 0,
    total: 0,
    datadate: '',
    data: [],
    positionplusdata: [],
    firstweek: [],
    lastweek: [],
    beforeweek: [],
    thisweekdatacore: 0,
    mounthbeforeday: 0,
    mounthfirstindex: 0,
    crispedges: 'crispedges',
    thisdayindex: 0,
    amonthagoindex: 0,
    amonthagoweek: [],
    firstdate: [],
    first2date: [],
    montharrbefore: [],
    monthindex: 0,
    color: ['#ebedf0', '#f1f8ff', '#dbedff', '#c8e1ff', '#79b8ff', '#2188ff', '#0366d6', '#005cc5', '#044289', '#032f62', '#05264c']
  },
  methods: {
    selectStyle(data, event) {
      document.querySelector('.angle-wrapper').style.display = 'block'
      this.span1 = data.date;
      this.span2 = data.count;
      this.x = event.clientX - 100;
      this.y = event.clientY - 60
    },
    outStyle() {
      document.querySelector('.angle-wrapper').style.display = 'none'
    },
    thiscolor(x) {
      if (x === 0) {
        let i = parseInt(x / 2);
        return this.color[0]
      } else if (x < 2) {
        return this.color[1]
      } else if (x < 20) {
        let i = parseInt(x / 2);
        return this.color[i]
      } else {
        return this.color[9]
      }
    },
  }
});
var apiurl = 'python-github-calendar-api-ruby.vercel.app' ? 'https://python-github-calendar-api-ruby.vercel.app/api?' : 'https://githubapi.ryanchristian.dev/user/'
var githubapiurl = apiurl + gitcalendar.user;
//canvas绘图
function responsiveChart() {
  let c = document.getElementById("gitcanvas");
  if (c) {
    let cmessage = document.getElementById("gitmessage");
    let ctx = c.getContext("2d");
    c.width = document.getElementById("gitcalendarcanvasbox").offsetWidth;
    let linemaxwitdh = 0.96 * c.width / gitcalendar.data.length;
    c.height = 9 * linemaxwitdh;
    let lineminwitdh = 0.8 * linemaxwitdh;
    let setposition = {
      x: 0.02 * c.width,
      y: 0.025 * c.width
    };
    for (let week in gitcalendar.data) {
      weekdata = gitcalendar.data[week];
      for (let day in weekdata) {
        let dataitem = {
          date: "",
          count: "",
          x: 0,
          y: 0
        };
        gitcalendar.positionplusdata.push(dataitem);
        ctx.fillStyle = gitcalendar.thiscolor(weekdata[day].count);
        setposition.y = Math.round(setposition.y * 100) / 100;
        dataitem.date = weekdata[day].date;
        dataitem.count = weekdata[day].count;
        dataitem.x = setposition.x;
        dataitem.y = setposition.y;
        ctx.fillRect(setposition.x, setposition.y, lineminwitdh, lineminwitdh);
        setposition.y = setposition.y + linemaxwitdh
      };
      setposition.y = 0.025 * c.width;
      setposition.x = setposition.x + linemaxwitdh
    };
    ctx.font = "600  Arial";
    ctx.fillStyle = '#aaa';
    ctx.fillText("日", 0, 1.9 * linemaxwitdh);
    ctx.fillText("二", 0, 3.9 * linemaxwitdh);
    ctx.fillText("四", 0, 5.9 * linemaxwitdh);
    ctx.fillText("六", 0, 7.9 * linemaxwitdh);
    let monthindexlist = c.width / 24;
    for (let index in gitcalendar.monthchange) {
      ctx.fillText(gitcalendar.monthchange[index], monthindexlist, 0.7 * linemaxwitdh);
      monthindexlist = monthindexlist + c.width / 12
    };
    cmessage.onmousemove = function(event) {
      document.querySelector('.angle-wrapper').style.display = 'none'
    };
    c.onmousemove = function(event) {
      document.querySelector('.angle-wrapper').style.display = 'none'
      getMousePos(c, event);
    };

    function getMousePos(canvas, event) {
      var rect = canvas.getBoundingClientRect();
      var x = event.clientX - rect.left * (canvas.width / rect.width);
      var y = event.clientY - rect.top * (canvas.height / rect.height);
      //console.log("x:"+x+",y:"+y);
      for (let item of gitcalendar.positionplusdata) {
        let lenthx = x - item.x;
        let lenthy = y - item.y;
        //console.log(lenthx,lenthy);
        if (0 < lenthx && lenthx < lineminwitdh) {
          if (0 < lenthy && lenthy < lineminwitdh) {
            //console.log(item.date,item.count)
            document.querySelector('.angle-wrapper').style.display = 'block'
            gitcalendar.span1 = item.date;
            gitcalendar.span2 = item.count;
            gitcalendar.x = event.clientX - 100;
            gitcalendar.y = event.clientY - 60
          }
        }
        //if(0< x - item.x <lineminwitdh&&0< y - item.y <lineminwitdh){
        //console.log(item.count,item.date);
        //}
      }
    }
  }
}
//数据统计算法
function addlastmonth() {
  if (gitcalendar.thisdayindex === 0) {
    thisweekcore(52);
    thisweekcore(51);
    thisweekcore(50);
    thisweekcore(49);
    thisweekcore(48);
    gitcalendar.thisweekdatacore += gitcalendar.firstdate[6].count;
    gitcalendar.amonthago = gitcalendar.firstdate[6].date
  } else {
    thisweekcore(52);
    thisweekcore(51);
    thisweekcore(50);
    thisweekcore(49);
    thisweek2core();
    gitcalendar.amonthago = gitcalendar.first2date[gitcalendar.thisdayindex - 1].date
  }
};

function thisweek2core() {
  for (let i = gitcalendar.thisdayindex - 1; i < gitcalendar.first2date.length; i++) {
    gitcalendar.thisweekdatacore += gitcalendar.first2date[i].count
  }
};

function thisweekcore(index) {
  for (let item of gitcalendar.data[index]) {
    gitcalendar.thisweekdatacore += item.count
  }
};

function addlastweek() {
  for (let item of gitcalendar.lastweek) {
    gitcalendar.weekdatacore += item.count
  }
};

function addbeforeweek() {
  for (let i = gitcalendar.thisdayindex; i < gitcalendar.beforeweek.length; i++) {
    gitcalendar.weekdatacore += gitcalendar.beforeweek[i].count
  }
};

function addweek(data) {
  if (gitcalendar.thisdayindex === 6) {
    gitcalendar.aweekago = gitcalendar.lastweek[0].date;
    addlastweek()
  } else {
    lastweek = data.contributions[51];
    gitcalendar.aweekago = lastweek[gitcalendar.thisdayindex + 1].date;
    addlastweek();
    addbeforeweek()
  }
}

fetch(githubapiurl)
  .then(data => data.json())
  .then(data => {
    gitcalendar.data = data.contributions;
    gitcalendar.total = data.total;
    gitcalendar.first2date = gitcalendar.data[48];
    gitcalendar.firstdate = gitcalendar.data[47];
    gitcalendar.firstweek = data.contributions[0];
    gitcalendar.lastweek = data.contributions[52];
    gitcalendar.beforeweek = data.contributions[51];
    gitcalendar.thisdayindex = gitcalendar.lastweek.length - 1;
    gitcalendar.thisday = gitcalendar.lastweek[gitcalendar.thisdayindex].date;
    gitcalendar.oneyearbeforeday = gitcalendar.firstweek[0].date;
    gitcalendar.monthindex = gitcalendar.thisday.substring(5, 7) * 1;
    gitcalendar.montharrbefore = gitcalendar.month.splice(gitcalendar.monthindex, 12 - gitcalendar.monthindex);
    gitcalendar.monthchange = gitcalendar.montharrbefore.concat(gitcalendar.month);
    addweek(data);
    addlastmonth();
    responsiveChart();
  })
  .catch(function(error) {
    console.log(error);
  });

//手机版更换为svg绘制
if (document.getElementById("gitcalendarcanvasbox").offsetWidth < 500) {
  gitcalendar.simplemode = false
}

//当改变窗口大小时重新绘制canvas
window.onresize = function() {
  if (gitcalendar.simplemode) responsiveChart()
}

//解决滚动滑轮时出现的标签显示
window.onscroll = function() {
  if (document.querySelector('.angle-wrapper')) {
    document.querySelector('.angle-wrapper').style.display = 'none'
  }
};</script></div><script src="/live2dw/lib/L2Dwidget.min.js?094cbace49a39548bed64abff5988b05"></script><script>L2Dwidget.init({"pluginRootPath":"live2dw/","pluginJsPath":"lib/","pluginModelPath":"assets/","tagMode":false,"log":false,"model":{"jsonPath":"/live2dw/assets/hijiki.model.json"},"display":{"position":"right","width":150,"height":300},"mobile":{"show":true},"react":{"opacity":0.7}});</script></body></html>